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(54) Authorization infrastructure based on public key cryptography 



(57) A public key authorization infrastructure (30) in- 
cludes a client program (34) accessible by a user and 
an application program (36, 38, 40). A certificate author- 
ity (32) issues a long-term certificate (60) that binds a 
public key (64) of the user to long-term identification in- 
formation (66) related to the user. A directory (42) stores 
the issued long-term certificate and short-term authori- 
zation information (77) related to the user. A credentials 
server (44) issues a short-term certificate (70) to the cli- 



ent. The short-term certificate binds the public key to the 
long-term identification information and to the short- 
term authorization information. The client presents the 
short-term certificate to the application program for au- 
thorization and demonstrates that the user has knowl- 
edge of a private key (48) corresponding to the public 
key in the short-term certificate. The short-term certifi- 
cate includes an expiration date, and is not subject to 
revocation. 
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Description 

The Field of the Invention 

[0001] The present invention relates to public key 5 
cryptosystems, and more particularly, to an authoriza- 
tion infrastructure based on public key cryptography that 
provides centralized authorization in a distributed sys- 
tem, such as an enterprise network. 

Background of the Invention 

[0002] Public key cryptosystems are globally de- 
ployed on the World Wide Web, as well as on a growing 
number of enterprise networks, for establishment of se- 
cure communication channels. Every user in a public 
key cryptosystem has a pair of keys including a public 
key and a private key. The public key is disclosed to oth- 
er users while the private key is kept secret. A public 
key cryptosystem typically has a primary designed use, 
such as for encryption, digital signature, or key agree- 
ment. Public key cryptosystems are also used for user 
authentication. For example, a user can authenticate it- 
self to other users by demonstrating knowledge of its 
private key, which other users can verify using the cor- 
responding public key. 

[0003] In an application of a public key cryptosystem 
for authenticating a user, the public key must be secure- 
ly associated with the identity of the user that owns the 
public key by authenticating the public key itself. Public 
key certificates are typically employed to authenticate 
the public key. A public key certificate is a digital docu- 
ment, signed by a certificate authority, that binds a public 
key with one or more attributes that uniquely identify the 
owner of the public key. The public key certificate can 
be verified using the certificate authority's public key, 
which is assumed to be well known or is recursively cer- 
tified by a higher authority. For example, in a corpora- 
tion, a public key certificate can bind a public key to an 
employee number. 

[0004] A public key infrastructure (PKI) refers to the 
collection of entities, data structures, and procedures 
used to authenticate public keys. A traditional PKI com- 
prises a certificate authority, public key certificates, and 
procedures for managing and using the public key cer- 
tificates. 

[0005] One type of a user of a PKI owns the public 
key contained in a public key certificate and uses the 
certificate to demonstrate the users identity. This type 
of user is referred to as the subject of the certificate or 
more generally as the subject. Another type of user re- 
lies on a public key certificate presented by another user 
to verify that the other user is the subject of the certifi- 
cate and that the attributes contained in the certificate 
apply to the other user. This type of user that relies on 
the certificate is referred to as a verifier or relying party. 
[0006] The association between a public key and an 
identity can become invalid because the attributes that 



define the identity no longer apply to the owner of the 
public key, or because the private key that corresponds 
to the public key has been compromised. A PKI typically 
employs two complementary techniques for dissociat- 
ing a public key from an identity. In the first technique, 
each public key certificate has a validity period defined 
by an expiration date, which is a substantial period from 
the issue date, such as one year from the issue date. In 
the second technique, the certificate authority revokes 
a public key certificate if the public key certificate's bind- 
ing becomes invalid before the expiration date. One way 
of revoking a public key certificate is by including a serial 
number of the public key certificate in a certificate rev- 
ocation list (CRL), which is signed and issued by the cer- 
tificate authority at known periodic intervals, such as 
every few hours or once a day. An entity that relies on 
a certificate is responsible for obtaining the latest ver- 
sion of the CRL and verifying that the serial number of 
the public key certificate is not on the list. 
[0007] CRLs typically become quite long very quickly. 
When the CRLs become long, performance is severely 
impacted. First, CRL retrieval consumes large amounts 
of network bandwidth. Second, each application has to 
retrieve the CRL periodically, parse the CRL, and allo- 
cate storage for the CRL. Then, the application needs 
to carry out a linear search of the CRL for the public key 
certificate serial number when the application verifies 
each public key certificate. 

[0008] An on-line certificate status protocol (OCSP) 
operates by permitting the verifier of the public key cer- 
tificate to ask the certificate authority if the certificate is 
currently valid. The certificate authority responds with a 
signed statement. The OCSP allows CRLs to be avoid- 
ed, but requires the verifier to query the certificate au- 
thority as part of the transaction that employs the public 
key certificates. The verifier querying the certificate au- 
thority increases the time it takes to perform the trans- 
action. The OCSP scheme is highly vulnerable to a de- 
nial-of-service attack, where the attacker floods the cer- 
tificate authority with queries. Responding to each query 
is computationally expensive, because each response 
requires a digital signature. 

[0009] Even though public key cryptography is used 
for authentication in distributed system security, public 
key cryptography has yet to be efficiently implemented 
into an authorization infrastructure for distributed sys- 
tems. However, substantial efforts have been made to 
extend public key cryptography to the area of authori- 
zation. For example, the Simple Public Key Infrastruc- 
ture (SPKI) working group of the Internet Society and 
the Internet Engineering Task Force has proposed au- 
thorization certificates that bind a public key to authori- 
zation information. See CM. Ellison, B. Frantz, B. 
Lampson, R. Rivest, B.M. Thomas and T. Ylonen, SPKI 
Certificate Theory, Request for Comments 2560 of the 
Internet Engineering Task Force, September 1999. 
However, the SPKI working group is concerned only 
with the format of authorization certificates rather than 
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the use of authorization certificates. 
[0010] The Transport Layer Security (TLS) working 
group of the Internet Society and the Internet Engineer- 
ing Task Force proposes using attribute certificates. See 
S. Farrell, TLS Extensions for Attribute Certificate- 5 
Based Authorization, Internet Draft, August 20, 1998; 
and Web Page of the TLS Working Group, http://www. 
ietf.org/html.charters/tls-charter.html . An attribute certif- 
icate binds a name to authorization information and 
does not contain a public key. A TLS client would be 
allowed to present an attribute certificate in addition to 
an ordinary public key certificate during the initial hand- 
shake. However, the TLS proposal only applies to the 
TLS protocol and does not explain how attribute certifi- 
cates are issued. Thus far, the efforts of the Internet So- 
ciety and the Internet Engineering Task Force have not 
yet provided a concrete blue print for solving the author- 
ization problem using public key cryptography. 
[0011] The security architecture of Microsoft's Win- 
dows 2000 addresses authentication and authorization 
at the scale of an enterprise network. However, the Win- 
dows 2000 security architecture is based on the sym- 
metric-key Kerberos protcol, with public-key enhance- 
ments that accommodate smart card authentication. 
Consequently, the Windows 2000 security architecture 
is inherently harder to manage, less scalable, and more 
vulnerable to attack than could be possible if the security 
architecture was entirely based on public-key cryptog- 
raphy. Moreover, the Windows 2000 security architec- 
ture's inter-operability with other Kerberos implementa- 
tions is limited. 

[0012] The Kerberos authorization infrastructure is 
based on symmetric key cryptography not public key 
cryptography. In Kerberos, symmetric keys must be 
shared between a Kerberos Key Distribution Center, the 
clients, and the applications. The shared symmetric 
keys must be set up by hand at great administrative ex- 
pense, or the shared symmetric keys must be set up 
using secured channels that are not part of the Kerberos 
infrastructure, which increases system complexity and 
vulnerability. Thus, in the Kerberos infrastructure, the 
key set up process provides an opportunity for attack. 
[0013] The security architecture of Microsoft Win- 
dows 2000 is based on an extension of Kerberos called 
Public Key Cryptography for Initial Authentication in Ker- 
beros (PKINIT). PKINIT allows public key cryptography 
to be used for user authentication. PKINIT makes it pos- 
sible to use smart cards for authentication. Neverthe- 
less, the Windows Domain Controller, which serves the 
role of the Kerberos Key Distribution Center in the Win- 
dows 2000 security architecture, must still share sym- 
metric keys with other computers on the network. When 
these computers are Windows based machines, the 
shared symmetric keys are distributed automatically. As 
in the case of the Kerberos infrastructure itself, this adds 
complexity and vulnerability to the protocol. When these 
computers are non-Windows based machines, the 
shared symmetric keys have to be installed by hand by 



the user administrator, which is quite costly and limits 
scalability. 

[0014] The Windows 2000 security architecture does 
not scale well beyond a single domain. Access to ma- 
chines in other domains relies on trust relationships 
along a hierarchy or a web of domain controllers, which 
is difficult to administer and introduces delays. 
[0015] Kerberos tickets used in the Windows 2000 se- 
curity architecture carry proprietary security identifiers 
(SIDs), which are used to obtain access to objects or 
properties of objects. Since, non-Windows based ma- 
chines and applications do not understand SIDs, inter- 
operability in a heterogeneous environment is limited. 
[0016] For reasons stated above and for other rea- 
sons presented in greater detail in the Description of the 
Preferred Embodiment section of the present specifica- 
tion, there is a need for an efficient authorization infra- 
structure based on public key cryptography which can 
provide centralized authorization in a distributed sys- 
tem, such as an enterprise network. 

Summary of the Invention 

[0017] The present invention provides a public key 
authorization infrastructure including a client program 
accessible by a user and an application program. A cer- 
tificate authority of the public key authorization infra- 
structure issues a long-term public key identity certifi- 
cate (long-term certificate). The long-term certificate 
binds a public key of the user to long-term identification 
information related to the user. A directory in the public 
key authorization infrastructure stores the issued long- 
term certificate. A credentials server of the public key 
authorization infrastructure issues a short-term public 
key credential certificate (short-term certificate) to the 
client. The short-term certificate binds the public key of 
the user to the long-term identification information relat- 
ed to the user from the long term certificate and to the 
short-term authorization information related to the user 
from the directory. The client presents the short-term 
certificate to the application program for authorization 
and demonstrates that the user has knowledge of a pri- 
vate key corresponding to the public key in the short- 
term certificate. 

[0018] In one embodiment, the short-term certificate 
includes an expiration date/time, and is not subject to 
revocation. A validity period from when the credentials 
server issues the short-term certificate to the expiration 
date/time is sufficiently short such that the short-term 
certificate does not need to be subject to revocation. In 
one embodiment, the public key authorization infra- 
structure includes a revocation mechanism, such as a 
certificate revocation list (CRL) or an on-line certificate 
status protocol (OCSP), for revoking the issued long- 
term certificate. If a CRL is employed, the expiration 
date/time is before a date/time at which the next new 
CRL is due. 

[0019] In one embodiment of the public key authori- 
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zation infrastructure according to the present invention, 
the directory also stores the issued long-term certificate. 
In one embodiment, the certificate authority gives the 
issued long-term certificate directly to the client pro- 
gram. 

[0020] In one embodiment, the short-term certificate 
is a non-structured short-term certificate. In another em- 
bodiment, the public key authorization infrastructure in- 
cludes a second application program and the short-term 
certificate is a structured short-term certificate having a 
first folder and a second folder. The first folder corre- 
sponds to the first application program and contains 
long-term information and short-term information as re- 
quired by the first application program. The second fold- 
er corresponds to the second application program and 
contains long-term information and short-term informa- 
tion as required by the second application. The first fold- 
er is open and the second folder is closed when the cli- 
ent presents the short-term certificate to the first appli- 
cation program for authorization. The first folder is 
closed and the second folder is open when the client 
presents the short-term certificate to the second appli- 
cation program for authorization. When a folder is 
closed its contents are not readable by the requested 
application program 

[0021] In one embodiment, the private key is stored 
in a secure storage medium, such as a smartcard or se- 
cure software wallet, which is accessible by the client 
program. 

[0022] The public key authorization infrastructure ac- 
cording to the present invention provides an efficient au- 
thorization infrastructure based on public key cryptog- 
raphy which can provide centralized authorization in a 
distributed system, such as an enterprise network. The 
public key authorization infrastructure according to the 
present invention utilizes short-term certificates, where 
all necessary authorization information is contained in 
the short-term certificate. Thus, the application does not 
need to access the directory storing the issued long- 
term certificate and the short-term authorization infor- 
mation related to the user. The short-term certificates 
each have an expiration date and are not subject to rev- 
ocation. Thus, the requested application does not need 
to use CRLs or other revocation mechanisms, such as 
OCSP. Furthermore, structured short-term certificates 
can be used to allow one short-term certificate to be 
used for more than one application. 

Brief Description of the Drawings 

[0023] Figure 1 is a block diagram of a public key au- 
thorization infrastructure having a credentials server ac- 
cording to the present invention. 
[0024] Figure 2 is a diagram of a long-term certificate 
as issued from a certificate authority. 
[0025] Figure 3 is a diagram of a non-structured short- 
term certificate as issued by a credentials server accord- 
ing to the present invention. 



[0026] Figure 4 is a diagram of a structured short-term 
certificate as issued from a credentials server according 
to the present invention. 

[0027] Figure 5 is a flow diagram illustrating a gener- 
alized authorization protocol for the public key authori- 
zation infrastructure of Figure 1. 
[0028] Figure 6 is a flow diagram illustrating a more 
detailed authorization protocol for the public key author- 
ization infrastructure of Figure 1 . 
[0029] Figure 7 is a flow diagram illustrating a network 
login phase of the authorization protocol of Figure 6. 
[0030] Figure 8 is a flow diagram illustrating an appli- 
cation access phase of the authorization protocol of Fig- 
ure 6. 

[0031] Figure 9 is a flow diagram illustrating a trans- 
action authorization phase of the authorization protocol 
of Figure 6. 

[0032] Figure 10isablockdiagramofacomputersys- 
tem and a corresponding computer readable medium 
incorporating one or more main software program com- 
ponents of the public key authorization infrastructure of 
Figure 1. 

Description of the Preferred Embodiments 

[0033] In the following detailed description of the pre- 
ferred embodiments, reference is made to the accom- 
panying drawings which form a part hereof, and in which 
is shown by way of illustration specific embodiments in 
which the invention may be practiced. It is to be under- 
stood that other embodiments may be utilized and struc- 
tural or logical changes may be made without departing 
from the scope of the present invention. The following 
detailed description, therefore, is not to be taken in a 
limiting sense, and the scope of the present invention is 
defined by the appended claims. 
[0034] A public key authorization infrastructure ac- 
cording to the present invention is illustrated generally 
at 30 in Figure 1 . Public key authorization infrastructure 
30 includes several main components which are each a 
software program. The main software program compo- 
nents of public key authorization infrastructure 30 run 
on one or more computer systems. In one embodiment, 
each of the main software program components runs on 
its own computer system. 

[0035] A certificate authority 32 issues long-term pub- 
lic key identity certificates (long-term certificates) to us- 
ers via the user's client program, such as client 34. A 
long-term certificate is herein defined as a public key 
certificate that binds a public key to one or more names 
or identifiers (i.e., long-term identification information). 
Examples of long-term identification information include 
name, social-security number, and employee number. 
The user receiving the long-term certificate is referred 
to as the subject of the certificate. Certificate authority 
32 optionally issues long-term certificates to application 
programs, such as application 36, application 38, and 
application 40. 
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[0036] For clarity, only a single certificate authority 32 
is illustrated in Figure 1. However, a typical public key 
authorization infrastructure according to the present in- 
vention includes a hierarchy or web of certificate author- 
ities. In addition, only one client 34 is illustrated in Figure 
1 , but each certificate authority in the public key author- 
ization infrastructure 30 according to the present inven- 
tion typically issues long-term certificates to numerous 
client programs. 

[0037] Certificate authority 32 distributes issued long- 
term certificates to client 34 and/or to a lightweight di- 
rectory access protocol (LDAP) directory 42 for storage. 
Long-term certificates typically have a validity period de- 
fined by an expiration date, which is a substantial period 
from the issue date, such as one year from the issue 
date. In addition, certificate authority 32 revokes a long- 
term certificate if the public key certificate binding be- 
comes invalid before the expiration date. One way of 
revoking a public key certificate is by including a serial 
number of the long-term certificate in a certificate revo- 
cation list (CRL), which is signed and issued by certifi- 
cate authority 32 at known periodic intervals, such as 
every few hours or once a day. Certificate authority 32 
can provide the CRLs to LDAP directory 42 for publica- 
tion in LDAP directory 42. 

[0038] Alternatively, the validity of a long-term certifi- 
cate is verified on-line by sending a certificate status in- 
quiry to certificate authority 32 using an on-line certifi- 
cate status protocol (OCSP). In the OCSP, the verifier 
of the long-term certificate sends the certificate status 
inquiry to certificate authority 32 and certificate authority 
32 responds thereto with a signed statement. 
[0039] A credential server 44 according to the present 
invention issues short-term public key credential certif- 
icates (short-term certificates) to users via the user's cli- 
ent program, such as client 34. Credential server 44 op- 
tionally issues short-term certificates to applications, 
such as applications 36, 38, and 40. Client 34 presents 
the short-term certificates to applications for authoriza- 
tion. Applications 36, 38, and 40 use trusted information 
about users which are contained in the short-term cer- 
tificates to make authorization decisions about the us- 
ers. 

[0040] Credentials server 44 automatically issues 
short-term certificates for submittal to applications 36, 
38, and 40 by client 34. Credentials server 44 automat- 
ically issues the short-term certificates based on long- 
term identification information contained in the long- 
term certificate and short-term information. 
[0041] In one embodiment, credentials server 44 ob- 
tains the short-term information data needed to issue 
the short-term certificates from LDAP directory 42. In 
this embodiment, since credentials server 44 does not 
contain this short-term information data, credentials 
server 44 is easily replicated within public key authori- 
zation infrastructure 30 for increased performance. 
[0042] The short-term information data contained in 
LDAP directory 42 relates to attribute or authorization 



information about the user (i.e. , subject). Example short- 
term authorization information includes expense author- 
ization limit for an enterprise application, co-payment 
amount for an insurance application, disk storage quota 

5 for an Information Technology (IT) application, and user 
ID plus group ID for Unix access application. 
[0043] Credentials server 44 includes a private key in- 
dicated at 46, which the credential server uses to sign 
short-term certificates. In a small to medium distributed 

io system, the public key corresponding to private key 46 
is typically well-known. In one example embodiment of 
a small to medium distributed system, the public key is 
configured into the entities that accept short-term certif- 
icates. In a large distributed system using public key au- 

15 thorization infrastructure 30, public key authorization in- 
frastructure 30 typically contains numerous credentials 
servers 44 having multiple private keys 46. In one em- 
bodiment of such a large distributed system, certificate 
authority 32 issues separate certificates to authenticate 

20 the corresponding public keys. For clarity, the following 
discussion assumes that the public key of credentials 
server44 corresponding to private key 46 is well-known. 
[0044] Client 34 has a private key 48 stored in a se- 
cure storage medium 50, such as a smartcard or secure 

25 software wallet. Client 34 also has a public key mathe- 
matically associated with private key 48. 
[0045] One embodiment of a long-term certificate is 
illustrated generally at 60 in Figure 2. Long-term certif- 
icate 60 includes a meta-data (MD) field 62 containing 

30 data about long-term certificate 60 itself rather than data 
related to the user. Long-term certificate 60 includes a 
user's public key (PK) 64. Long-term certificate 60 in- 
cludes long-term information (LTI) 66 containing long- 
term information related to the user, such as the user's 

35 name, the user's social security number, or the user's 
employee number. After being issued from certificate 
authority 32, long-term certificate 60 includes a certifi- 
cate authority's signature 68. 

[0046] One embodiment of a short-term certificate is- 
40 sued by credential server 44 is illustrated generally at 
70 in Figure 3. Short-term certificate 70 is a non-struc- 
tured certificate associated with one of applications 36, 
38, or 40. Short-term certificate 70 includes a meta-data 
(MD) field 72 containing data about short-term certifi- 
es cate 70 rather than the user of short-term certificate 70. 
Short-term certificate 70 includes a public key (PK) 74 
which is the same public key as public key 64 of long- 
term certificate 60. The user of long-term certificate 60 
and short-term certificate 70 has only one private-public 
50 key pair associated with private key 48 of smartcard or 
secure software wallet 50. Short-term certificate 70 in- 
cludes long-term information 76 which is identical to 
long-term information 66 of long-term certificate 60. 
Short-term certificate 70 also includes short-term infor- 
55 mation 77, which contains attribute or authorization in- 
formation, such as expense authorization limit foran en- 
terprise application, co-payment amount for an insur- 
ance application, disk storage quota for an IT applica- 
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tion, or user ID plus group ID for Unix access application. 
Short-term certificate 70 as issued from credential serv- 
er 44 contains a credentials server's 44 signature 78. In 
one embodiment, non-structured short-term certificate 
70 is implemented with a X.509v3 certificate. 
[0047] An alternative embodiment of a short-term cer- 
tificate issued by credentials server 44 is illustrated gen- 
erally at 80 in Figure 4. Short-term certificate 80 is a 
structured certificate, such as the structured certificates 
defined and described in co-pending application entitled 
"METHOD AND APPARATUS FOR PROVIDING FIELD 
CONFIDENTIALITY IN DIGITAL CERTIFICATES," 
which is incorporated by reference above. Structured 
short-term certificate 80 includes a meta-data field (MD) 
field 82, a users public key (PK) 84, and a credentials 
server's signature 88, which are substantially similar to 
meta-data field 72, public key 74, and signature 78 of 
non-structured short-term certificate 70 of Figure 3. 
Structured short-term certificate 80, however, includes 
folders 85a, 85b, and 85c, which respectively corre- 
spond to application 36, application 38, and application 
40. Folder 85a contains long-term information 86a and 
short-term information 87a as required by application 36 
to make authorization decisions about the user of client 
34. Similarly, folder 85b includes long-term information 
86b and short-term information 87b as required by ap- 
plication 38 to make authorization decisions about the 
user of client 34. Similarly, folder 85c includes long-term 
information 86c and short-term information 87c as re- 
quired by application 40 to make authorization decisions 
about the user of client 34. In one embodiment, struc- 
tured short-term certificate 80 is implemented by adding 
a folder extension to a X.509v3 certificate. 
[0048] In one embodiment, the validity period of non- 
structured short-term certificate 70 or structured short- 
term certificate 80 is indicated by an expiration date/time 
sub-field in meta-data field 72/82. In one embodiment, 
credentials server 44 itself determines the duration of 
the validity period of short-term certificate 70/80 for set- 
ting the expiration date/time sub-field. In an alternative 
embodiment, credentials server 44 obtains the duration 
of the validity period of short-term certificate 70/80 from 
meta-data field 62 in long-term certificate 60 for setting 
the expiration date/time sub-field. 
[0049] The validity period of short-term certificate 
70/80 is substantially equivalent, from the point of view 
of security, to the update period of the CRL stored in 
LDAP directory 42. However, the validity period of short- 
term certificate 70/80 in some embodiments of the in- 
vention is much shorter than the update period of the 
CRL. For example, the validity period of short-term cer- 
tificate 70/80 can be a few hours or even as short as a 
few minutes. 

[0050] Client 34 of public key authorization infrastruc- 
ture 30 of Figure 1 is a program or process running on 
behalf of the user of the public key. Example client 34 
programs include an operating system of a single-user 
personal computer and a login shell of a Unix worksta- 



tion. Client 34 has access to the user's private key 48 
stored in smartcard or secure software wallet 50. 
[0051] LDAP directory 42 is suitably a standard LDAP 
directory. For each application (e.g., application 36, ap- 
5 plication 38, and application 40) requiring authorization, 
a primary directory entry in LDAP directory 42 specifies 
a set of attributes of a user entry in the LDAP directory 
that are relevant to authorization decisions made by the 
corresponding application. In one embodiment, author- 
io ization information attributes are a set of relevant at- 
tributes provided as the set of values of a multi-valued 
attribute in the application entry in LDAP directory 42. 
In one embodiment employing structured short-term 
certificates, the primary directory entry in LDAP directo- 
rs ry 42 specifies which attributes in a user entry in the 
LDAP directory must be included in the folder for the 
application. 

[0052] For each user, LDAP directory 42 contains an 
entry having attributes assigning roles and other author- 

20 ization-related parameters to the user. These authoriza- 
tion-related parameters typically are application-inde- 
pendent rather than application-specific. Examples of 
application-independent parameters are "management 
scope = 64" and "employer = XYZ" in an example appli- 

25 cation for XYZ Partner Company having employees as- 
signed restrictive access to the XYZ corporate network. 
Dependent application entries in LDAP directory 42 re- 
side below a user entry and refer to entries for applica- 
tions that are accessible by the user. The entry in LDAP 

30 directory 42 for each application contains attributes that 
assign application-specific parameters to the user rep- 
resented by the parent entry. Examples of application- 
specific paramters are "user ID = 23" and "group ID = 
4" in the application of a login shell of a Unix work sta- 

35 tion. 

[0053] When client 34 requests credentials server 44 
to issue a structured short-term certificate, such as 
structured short-term certificate 80 of Figure 4, client 34 
can specify the list of applications for which folders are 

40 to be created. In one embodiment, a user profile is em- 
ployed to generate the list of applications for which fold- 
ers are to be created. If at some point an additional folder 
is required for a structured short-term certificate, the ad- 
ditional folder is added by issuing a new structured 

45 short-term certificate. 

[0054] A generalized authorization protocol for public 
key authorization infrastructure 30 is illustrated gener- 
ally at 100 in Figure 5. At step 102, certificate authority 
32 issues a long-term certificate to client 34 for the us- 

50 er's public key. Step 102 for issuing the long-term cer- 
tificate is performed only once. 
[0055] At step 1 04, client 34 submits the issued long- 
term certificate to credentials server44. At step 1 06, cre- 
dentials server 44 verifies the validity of the long-term 

55 certificate. In an enterprise environment, steps 1 04 and 
1 06 are performed when the user logs into the network. 
[0056] An optional step 108 is required only if the 
short-term certificate contains confidential information. 
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In step 1 08, client 34 demonstrates to credentials server 
44 that client 34 has access to the user's private key 48. 
In one embodiment, step 108 is performed as part of a 
Secure Sockets Layer (SSL) handshake by using client 
34's certificate option. In an enterprise environment, 
step 1 08 is performed when the user logs into the net- 
work. 

[0057] At step 110, credentials server 44 obtains 
short-term information from LDAP directory 42. If cre- 
dentials server 44 and LDAP directory 42 are on differ- 
ent computer systems, a communication channel be- 
tween the computer systems is preferably protected, 
such as by SSL or host-to-host Internet Protocol Secu- 
rity (IPSEC). In an enterprise environment, step 110 is 
performed when the user logs into the network. 
[0058] At step 112, credentials server 44 issues a 
short-term certificate to client 34. In one embodiment, 
the short-term certificate is a structured short-term cer- 
tificate, such as structured short-term certificate 80 illus- 
trated in Figure 4, having one folder (e.g., 85a, 85b, and 
85c) for each application (e.g., 36, 38, and 40). At step 
112, all folders 85 are open. Thus, if any of folders 85 
contain confidential information and a communication 
channel between credentials server 44 and client 34 is 
not deemed secure, transmission between credentials 
server 44 and client 34 must be encrypted, such as by 
SSL or host-to-host IPSEC. In an enterprise environ- 
ment, step 112 is performed when the user logs into the 
network. 

[0059] At step 114, client 34 submits the short-term 
certificate to an application, such as application 38. In 
an example step 114 where application 38 receives the 
short-term certificate from client 34, folders 85a and 85c 
are closed and a hash of the contents of folders 85a and 
85c replace the contents of folders 85a and 85c. In this 
example step 114, folder 85b corresponding to applica- 
tion 38 remains open. Thus, if folder 85b contains con- 
fidential information and a communication channel be- 
tween client 34 and application 38 is not deemed se- 
cure, transmission between client 34 and application 38 
must be encrypted, such as by SSL or host-to-host 
IPSEC. 

[0060] At step 116, client 34 demonstrates to applica- 
tion 38 that client 34 has access to the user's private key 
48. In one embodiment, step 116 is performed as part 
of a SSL handshake using the client 34's certificate op- 
tion. 

[0061] At step 118, client 34 interacts with the select- 
ed application, such as application 38. In step 118, data 
integrity protection must be provided to prevent connec- 
tion hi-jacking or other man-in-the-middle attacks. Suit- 
able data integrity protection is accomplished with SSL 
or host-to-host IPSEC. 

[0062] A more detailed authorization protocol for pub- 
lic key authorization infrastructure 30 is illustrated gen- 
erally at 200 in Figure 6. Authorization protocol 200 in- 
cludes three phases. As indicated at 202, a phase I oc- 
curs when a user logs into the network via client 34. As 



indicated at 204, phase II occurs when the user of client 
34 attempts to access an application, such as applica- 
tion 36, 38, or 40. As indicated at 206, phase III occurs 
when the user, while using an application, issues a 

5 transaction that requires specific authorization. 

[0063] Some embodiments of public key authoriza- 
tion infrastructure 30 only implement phase I of author- 
ization protocol 200. More typically, however, embodi- 
ments of public key authorization infrastructure 30 im- 

io plement phase I and phase II of authorization protocol 
200. Some embodiments of public key authorization in- 
frastructure 30 implement all three phases of authoriza- 
tion protocol 200. Currently, few authorization infrastruc- 
tures implement authorization on a per-transaction ba- 

15 sis. The Praesidium line of authorization products, how- 
ever, performs authorization on a per-transaction basis. 
[0064] The network login phase I of authorization pro- 
tocol 200 is generally illustrated at 202 in Figure 7. The 
network login phase I occurs when the user logs into 

20 client 34 with an intention of accessing the network. The 
user may be able to locally login to client 34 as a stand- 
alone resource, but such a local login is not addressed 
herein. 

[0065] At step 302, the user inserts smartcard 50 in a 

25 card reader of client 34. Smartcard 50 contains the us- 
er's name and private key 48. In one embodiment, two- 
factor authentication is employed, and the user also en- 
ters a PIN number on the card reader or a password at 
the terminal of client 34. 

30 [0066] At step 304, client 34 retrieves the user's long- 
term certificate, such as long-term certificate 60. The 
long-term certificate binds the user's name to the user's 
public key and has a relatively long validity period, such 
as one year. In one embodiment, the long-term certifi- 

35 cate is stored in LDAP directory 42 but is cached in client 
34, so that client 34 typically retrieves the long-term cer- 
tificate from its cache rather than having to access the 
LDAP directory. Client 34 does not verify the validity of 
the long-term certificate after the long-term certificate is 

40 issued by certificate authority 32. Instead, credentials 
server 44 verifies the validity of the long-term certificate 
as described below with reference to step 310. 
[0067] At step 306, client 34 conducts a hand-shake 
with smartcard 50 to verify that private key 48 corre- 

45 sponds to the public key contained in the long-term cer- 
tificate. In one embodiment, step 306 is performed by 
client 34 issuing a random challenge to smartcard 50. 
Smartcard 50 combines the challenge with a fresh ran- 
dom value, signs the result, and returns the signature 

50 together with the random value. Client 34 then verifies 
the signature using the public key contained in the long- 
term certificate. 

[0068] At step 308, client 34 submits the long-term 
certificate to credentials server 44 as follows. First, di- 
ss ent 34 contacts credentials server 44 and sends the us- 
er's long-term certificate and a list of frequently used se- 
cure applications. Secure applications are herein de- 
fined as applications requiring authorization. The list of 
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frequently used secure applications is herein referred to 
as the secure applications list (SAL). The SAL is ob- 
tained from a user's profile. In one embodiment, the us- 
er's profile is stored in client 34. In an alternative em- 
bodiment, the user profile is stored in LDAP directory 5 
42. If client 34 has a graphical user interface (GUI), the 
user can designate the SAL applications, for example, 
by grouping the applications in a special desktop folder. 
Each application is specified by name in the SAL. In one 
embodiment, the specified application name is the 
LDAP distinguished name of its primary directory entry. 
In one embodiment, the specified application name is a 
Uniform Resource Locator (URL). 
[0069] As step 310, credentials server 44 verifies that 
the user's long-term certificate is valid. Step 310 in- 
cludes the step of verifying certificate authority 32's sig- 
nature on the long-term certificate and checking that the 
long-term certificate has not expired. In addition, cre- 
dentials server 44 is required to check that the long-term 
certificate has not been revoked. In the embodiment 
where certificate authority 32 employs CRLs for revoca- 
tion, credentials server 44 checks whether the creden- 
tials server has the CRL currently in force. If credentials 
server44 does not have the current CRL, the credentials 
server retrieves the current CRL from LDAP directory 
42. Credentials server44 then verifies that the long-term 
certificate's serial number is not on the current CRL. 
[0070] At step 312, credentials server 44 obtains the 
directory entries of LDAP directory 42 for the SAL appli- 
cations. Credentials server 44 further extracts the au- 
thorization information attributes from these entries. 
Credentials server 44 typically caches application en- 
tries, so that no actual LDAP directory access is required 
to carry out step 312. 

[0071] At step 314, credentials server 44 accesses 
LDAP directory 42 and retrieves the entry associated 
with the user. Credentials server 44 also retrieves any 
dependent application entries below the user entry of 
LDAP directory 42. 

[0072] At step 316, credentials server 44 constructs 
and signs the short-term certificate for the user. In one 
embodiment, this is a structured short-term certificate, 
such as structured short-term certificate 80 illustrated in 
Figure 4. The short-term certificate has a short validity 
period, such as a few hours, and is not subject to revo- 
cation. The short-term certificate binds the following in- 
formation together. First, the user's public key, which is 
a field copied from the long-term certificate. Second, 
one or more fields copied from the long-term certificate 
and containing the user's name or other identifiers. 
Third, for each SAL application, a folder containing: the 
name of the application; the (attribute, set-of-values) 
pairs contained in the user entry for attributes specified 
by the authorization information attribute of the primary 
directory entry for the application; and if there is a de- 
pendent entry for the application below the user entry, 
the (attribute, set-of-values) pairs in that entry. If the ap- 
plication has no primary entry, or the primary entry has 



no authorization information attribute, and the applica- 
tion has no dependent entry below the user entry, then 
the folder is omitted. 

[0073] At step 318, credentials server 44 sends the 
short-term certificate to the user, with all folders open. 
Since all folders are open, protection from potential 
eavesdropping is possibly required. If such protection is 
required, credentials server 44 authenticates the user 
and encrypts the transmission. In one embodiment, user 
authentication is performed by a challenge-response 
handshake between credentials server 44 and smart- 
card 50, substantially similar to the handshake per- 
formed in step 306 between client 34 and smartcard 50. 
[0074] At step 320, if usage of client 34 itself requires 
authorization, client 34 verifies that the public key in the 
short-term certificate is the same as the public key in the 
long-term certificate that was used in step 306 to au- 
thenticate smartcard 50. Client 34 then uses the short- 
term certificate to decide whether the user is allowed to 
login the network. 

[0075] At step 322, client 34 stores the short-term cer- 
tificate while the user is logged in the network. Client 34 
schedules a short-term certificate renewal operation, 
which is scheduled for a time before the short-term cer- 
tificate expires. A short-term certificate renewal opera- 
tion includes repeating steps 308 through 320 of phase 
I of authorization protocol 200. 

[0076] In one embodiment, a security policy requires 
that steps 302 through 306 of Phase I of authorization 
protocol 200 be repeated after a defined period of inac- 
tivity, or at regular intervals, to verify that it is actually 
the user who is interacting with client 34. 
[0077] The application access Phase II of authoriza- 
tion protocol 200 of public key authorization infrastruc- 
ture 30 is illustrated generally at 204 in Figure 8. The 
application access phase II occurs when the user at- 
tempts to access a secure application. 
[0078] At step 402, client 34 verifies that the applica- 
tion (e.g., application 36, 38, or 40) is in the SAL. If the 
application is not in the SAL, client 34 adds the applica- 
tion to the SAL, and the application remains in the SAL 
for the remaining time of the current login session. In 
step 402, if the application is added to the SAL, a cer- 
tificate renewal operation is executed using the new 
SAL by implementing phase I network login steps 308 
through 320 of authorization protocol 200 as described 
above in reference to Figure 7. 
[0079] At step 404, client 34 verifies that the short- 
term certificate is still valid. The short-term certificate will 
be valid unless client 34 is prevented from performing a 
scheduled certificate renewal operation due to a net- 
work failure, a credentials server44 failure, or some oth- 
er failure or error. 

[0080] At step 406, client 34 closes all folders in the 
short-term certificate for applications other than the re- 
quested application. In the case where there is no folder 
for the application in the short-term certificate, all folders 
in the short-term certificate are closed. Nevertheless, 
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the short-term certificate includes fields outside the fold- 
ers including the user's public key and the user's iden- 
tification information copied from the long-term certifi- 
cate. The fields outside the folders remain visible after 
all of the folders are closed. 

[0081] At step 408, client 34 sends the short-term cer- 
tificate to the requested application. At step 410, the re- 
quested application verifies the short-term certificate. In 
step 410, the requested application verifies the signa- 
ture of credentials server 44 contained in the short-term 
certificate. The requested application also checks that 
the short-term certificate has not expired. The requested 
application does not have to check whether the short- 
term certificate has been revoked, because short-term 
certificates are not subject to revocation. 
[0082] At step 412, the requested application authen- 
ticates the user. In one embodiment, the application au- 
thenticates the user by issuing a random challenge, 
which client 34 forwards to smartcard 50 that contains 
the user's private key 48. Smartcard 50 combines the 
challenge with a fresh random value and signs the re- 
sult. Client 34 forwards the signature and the client's 
random value to the application, which verifies the sig- 
nature using the public key contained in the short-term 
certificate. 

[0083] At decision step 414, the requested application 
decides whether to grant or deny access to the user. In 
step 414, the application employs the information in the 
visible fields of the short-term certificate. 
[0084] Step 416 is performed if access is denied to 
the user in decision step 414. In step 41 6, client 34 flush- 
es the authorization information attribute of the applica- 
tion from client 34's cache because the authorization in- 
formation attribute of the application may be out of date. 
In step 416, the phase I network login steps 308 through 
320 of authorization protocol 200 and the phase II ap- 
plication access steps 402 through 414 of authorization 
protocol 200 are repeated. If the user's smartcard 50 is 
in the card reader, the step repetition is transparent to 
the user, unless one of the security checks involved in 
the repeated steps fails. If the user is denied access 
once again in step 414 of phase II of authorization pro- 
tocol 200, the denied access is reported to the user. 
[0085] Step 418 is performed if access is granted in 
decision step 414 and if the requested application pos- 
sibly requires later authorization for a specific transac- 
tion. In step 418, the application stores the short-term 
certificate received from the user. 
[0086] In some cases, such as when the user must 
transmit sensitive data to the application, the user au- 
thenticates the application. In order for the user to be 
able to authenticate the application, the application must 
have a private key and a corresponding public key au- 
thenticated by a certificate. In one embodiment, the cer- 
tificate is a long-term certificate issued by certificate au- 
thority 32. In a preferred embodiment, the certificate is 
a short-term certificate issued by credentials server 44. 
The user then authenticates the application by using a 



challenge-response protocol substantially similar to the 
phase II steps 408, 410, and 412, except that the appli- 
cation and client 34 swap roles. 
[0087] The transaction authorization phase III of au- 

5 thorization protocol 200 is generally illustrated at 206 in 
Figure 9. The transaction authorization phase III occurs 
when the user initiates a transaction that requires spe- 
cific authorization by the application. 
[0088] At step 502, the application checks whether 

io the user's short-term certificate, which was stored by the 
application at step 418 of phase II of authorization pro- 
tocol 200, has expired. If the short-term certificate has 
expired, the application rejects the transaction with an 
error message indicating that the short-term certificate 

15 has expired. 

[0089] At step 504, when the application rejects the 
transaction in step 502, client 34 has a valid short-term 
certificate, unless a network failure or some other failure 
has occurred. Thus, all steps 402 through 418 of the ap- 

20 plication access phase II of authorization protocol 200 
and step 502 of the transaction authorization phase III 
of authorization protocol 200 are repeated. At this point, 
step 502 should succeed in determining that the user's 
short-term certificate has not expired. If the user's 

25 smartcard 50 is in the card reader, the repeated steps 
are transparent to the user, unless one of the security 
checks in the repeated steps fails. 
[0090] Step 506 is optionally performed if at step 502 
the application determines that the user's short-term 

30 certificate has not expired. Step 506 is an optional step 
where the application reauthenticates the user using 
substantially the same procedure as in step 412 of 
phase II of authorization protocol 200. If the user's pri- 
vate key 48 is contained in smartcard 50, step 506 en- 

35 sures that smartcard 50 is still in the card reader. Step 
506 is an optional step which only needs to be per- 
formed when reauthentication is absolutely necessary 
for extremely sensitive transactions. If reauthentication 
fails, the transaction is rejected. Client 34 can request 

40 the user to reinsert smartcard 50 into the card reader 
and the transaction can be retried. 
[0091] At step 508, the application uses the informa- 
tion contained in the visible fields of the short-term cer- 
tificate, as well as transaction data, to decide whether 

45 to reject or accept the transaction. 

[0092] At step 510, if the transaction is rejected in step 
508, client 34 flushes the authorization information at- 
tribute of the application from client 34's cache, because 
the authorization information attribute may be out of 

50 date. Then, the phase I network login steps 308 through 
320, the application access phase II steps 402 through 
418, and the phase III transaction authorization steps 
502 through 508 of authorization protocol 200 are re- 
peated. If the user's smartcard 50 is in the card reader, 

55 the repetition of steps is transparent to the user, unless 
one of the security checks involved in the repeated steps 
fails. If the transaction is rejected again in step 508 of 
phase III of authorization protocol 200, the rejection is 



17 



EP1 117 204 A2 



18 



reported to the user. 

[0093] The above-described authorization protocol 
200 employs digital signatures from any suitable digital 
signature cryptosystem, such as RSA, which is a public- 
key cryptosystem for encryption and digital signature 5 
developed by RSA Data Security, Inc. Other suitable 
digital signature cryptosystems are Digital Signature Al- 
gorithm (DSA), which is adopted as a standard by the 
National Institute of Standards and Technology (NIST), 
and Elliptic Curve Digital Signature Algorithm (ECDSA). 
[0094] The security of authorization protocol 200 does 
not rely on the security of the communication channel 
between client 34 and credentials server 44. Therefore, 
the network login phase I of authorization protocol 200 
can be implemented using a simple Transmission Con- 
trol Protocol (TCP) connection, or even an exchange of 
User Datagram Protocol (UDP) datagrams between cli- 
ent 34 and credentials server 44. In an embodiment 
where confidentiality of the short-term certificate must 
be protected in step 318 of phase I of authorization pro- 
tocol 200, a secure Transport Layer Security (TLS) or 
SSL connection between client 34 and credentials serv- 
er 44 is used. In this embodiment, client 34 may authen- 
ticate credentials server 44, and if so step 306 of phase 
I of authorization protocol 200 may be omitted. 
[0095] Similarly, security of authorization protocol 200 
does not need to rely on the security of the communica- 
tion channel between client 34 and the application. Nev- 
ertheless, phase II of authorization protocol 200 speci- 
fies authentication of the user by the application and op- 
tional authentication of the application by the user. If cli- 
ent 34 and the application run on different computer sys- 
tems, then client 34 and the application use a protocol 
such as File Transfer Protocol (FTP), Telnet, or Hyper 
Text Transfer Protocol (HTTP) to communicate. 
[0096] One approach to providing authentication in 
conjunction with the selected communication protocol 
from communicating between client 34 and the applica- 
tion is to extend the existing communication protocol to 
add authentication. Methods have been proposed for 
extending the FTP and Telnet communication protocols. 
If structured short-term certificates are implemented as 
extensions of X.509v3 certificates, these methods could 
be used to implement the application access phase II of 
authorization protocol 200. 

[0097] A second approach to providing authentication 
in conjunction with the selected communication protocol 
for communicating between client 34 and the application 
is to use TLS to secure the existing communication pro- 
tocol. TLS can be inserted in the protocol stack between 
TCP and FTP and between TCP and Telnet. HTTP over 
SSL, which is the predecessor to TLS, is widely used to 
provide access to secure documents on the World Wide 
Web. TLS can accomplish, without modification, the us- 
er authentication and the optional application authenti- 
cation required by phase II of authentication protocol 
200, provided that the structured short-term certificates 
are implemented as extensions of X.509v3 certificates. 



The second approach has an advantage that it provides 
confidentiality and integrity protection for the data ex- 
changed between client 34 and the application. 
[0098] Figure 10 illustrates one embodiment of a com- 
puter system 250 and an external computer readable 
medium 252 which can be employed according to the 
present invention to implement one or more of the main 
software program components of public key authoriza- 
tion infrastructure 30. Embodiments of external compu- 
ter readable medium 252 include, but are not limited to: 
a CD-ROM, a floppy disk, and a disk cartridge. Any one 
of the main software program components of public key 
authorization infrastructure 30 can be implemented in a 
variety of compiled and interpreted computer languag- 
es. External computer readable medium 252 stores 
source code, object code, executable code, shell scripts 
and/or dynamic link libraries for any one of the main soft- 
ware program components of public key authorization 
infrastructure 30. An input device 254 reads external 
computer readable medium 252 and provides this data 
to computer system 250. Embodiments of input device 
254 include but are not limited to: a CD-ROM reader, a 
floppy disk drive, and a data cartridge reader. 
[0099] Computer system 250 includes a central 
processing unit 256 for executing any one of the main 
software program components of public key authoriza- 
tion infrastructure 30. Computer system 250 also in- 
cludes local disk storage 262 for locally storing any one 
of the main software program components of public key 
authorization infrastructure 30 before, during, and after 
execution. Any one of the main software program com- 
ponents of public key authorization infrastructure 30 al- 
so utilizes memory 260 within the computer system dur- 
ing execution. Upon execution of any one of the main 
software program components of public key authoriza- 
tion infrastructure 30, output data is produced and di- 
rected to an output device 258. Embodiments of output 
device 258 include, but are not limited to: a computer 
display device, a printer, and/or a disk storage device. 

Conclusion 

[0100] The public key authorization infrastructure 30 
according to the present invention utilizes short-term 
certificates, such as non-structured short-term certifi- 
cate 70 or structured short-term certificate 80, which are 
not subject to revocation. Thus, the requested applica- 
tion does not need to use CRLs or other revocation 
methods such as OCSP. The structured short-term cer- 
tificates, such as structured short-term certificate 80, al- 
low one short-term certificate to be used for more than 
one application. Moreover, all necessary authorization 
information is contained in the short-term certificate. 
Thus, the application does not need to access the LDAP 
directory 42. Overall, public key authorization infrastruc- 
ture 30 permits the application to be greatly simplified. 
[0101] Although specific embodiments have been il- 
lustrated and described herein for purposes of descrip- 
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tion of the preferred embodiment, it will be appreciated 
by those of ordinary skill in the art that a wide variety of 
alternate and/or equivalent implementations calculated 
to achieve the same purposes may be substituted for 
the specific embodiments shown and described without 
departing from the scope of the present invention. 
Those with skill in the chemical, mechanical, electro- 
mechanical, electrical, and computer arts will readily ap- 
preciate that the present invention may be implemented 
in a very wide variety of embodiments. This application 
is intended to cover any adaptations or variations of the 
preferred embodiments discussed herein. Therefore, it 
is manifestly intended that this invention be limited only 
by the claims and the equivalents thereof. 



Claims 

1. A public key authorization infrastructure (30) com- 
prising: 

a client program (34) accessible by a user; 
an application program (36, 38, 40); 
a certificate authority (32) issuing a long-term 
public key identity certificate (long-term certifi- 
cate) (60) that binds a public key (64) of the us- 
er to long-term identification information (66) 
related to the user; 

a directory (42) for storing short-term authori- 
zation information related to the user; and 
a credentials server (44) for issuing a short- 
term public key credential certificate (short- 
term certificate) (70) to the client, the short-term 
certificate binds the public key of the user to the 
long-term identification information related to 
the user from the long term certificate and to 
the short-term authorization information (77) 
related to the user from the directory, wherein 
the client program presents the short-term cer- 
tificate to the application program for authoriza- 
tion and demonstrates that the user has knowl- 
edge of a private key (48) corresponding to the 
public key in the short-term certificate. 

2. The public key authorization infrastructure of claim 

1 wherein the short-term certificate includes an ex- 
piration date/time. 

3. The public key authorization infrastructure of claim 

2 wherein a validity period from when the creden- 
tials server issues the short-term certificate to the 
expiration date/time is sufficiently short such that 
the short-term certificate does not need to be sub- 
ject to revocation. 

4. The public key authorization infrastructure of claim 
2 further comprising: 

a certificate revocation list (CRL), wherein the 



expiration date/time of the short-term certificate is 
no later than a date/time at which a next CRL is 
scheduled. 

5 5. The public key authorization infrastructure of claim 
1 or 2 wherein the short-term certificate is not sub- 
ject to revocation. 

6. The public key authorization infrastructure of claim 
io 1 wherein the short-term certificate is a non-struc- 
tured short-term certificate. 

7. The public key authorization infrastructure of claim 
1 further comprising: 

15 

a second application program; and 
wherein the short-term certificate is a struc- 
tured short-term certificate including: 
a first folder corresponding to the first named 
20 application program and containing long-term 

information and short-term information as re- 
quired by the first named application program; 
a second folder corresponding to the second 
application program and containing long-term 
25 information and short-term information as re- 

quired by the second application; 
wherein the first folder is open and the second 
folder is closed when the client presents the 
short-term certificate to the first named applica- 
30 tion program for authorization, wherein closing 

the second folder makes its contents not read- 
able by the first named application program; 
and 

wherein the first folder is closed and the second 
35 folder is open when the client presents the 

short-term certificate to the second application 
program for authorization, wherein closing the 
first folder makes its contents not readable by 
the second application program. 

40 

8. The public key authorization infrastructure of claim 
7 wherein the short-term certificate is an X.509v3 
certificate and wherein the first folder and the sec- 
ond folder are implemented as extension fields of 

45 the X.509v3 certificate. 

9. A method of authorizing a user, the method com- 
prising the steps of: 

50 issuing a long-term public key identity certifi- 

cate (long-term certificate) (60) that binds a 
public key (64) of the user to long-term identifi- 
cation information (66) related to the user; 
storing short-term authorization information 
55 (77) related to the user; 

issuing a short-term public key credential cer- 
tificate (short-term certificate) (70) that binds 
the public key of the user to the long-term iden- 
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tification information related to the user con- 
tained in the long-term certificate and to the 
short-term authorization information related to 
the user; and 

presenting the short-term certificate on behalf 5 
of the user to an application program (36, 38, 
40) for authorization and demonstrating that the 
user has knowledge of a private key (48) cor- 
responding to the public key in the short-term 



application program. 

16. The method of claim 9 wherein the short-term cer- 
tificate is an X.509v3 certificate and wherein the first 
folder and the second folder are implemented as ex- 
tension fields of the X.509v3 certificate. 



10. The method of claim 9 wherein the short-term cer- 
tificate includes an expiration date/time. 

11. The method of claim 10 wherein a validity period 15 
from when the short-term certificate is issued to the 
expiration date/time is sufficiently short such that 

the short-term certificate does not need to be sub- 
ject to revocation. 

20 

12. The method of claim 1 0 further comprising the step 
of: 

maintaining a certificate revocation list (CRL), 
wherein the expiration date/time of the short-term 
certificate is no later than a time at which the next 25 
CRL is scheduled. 



1 3. The method of claim 9 or 1 0 wherein the short-term 
certificate is not subject to revocation. 

14. The method of claim 9 wherein the short-term cer- 
tificate is a non-structured short-term certificate. 



15. The method of claim 9 wherein the short-term cer- 
tificate is a structured short-term certificate includ- 35 
ing a first folder corresponding to the first named 
application program and containing long-term infor- 
mation and short-term information as required by 
the first named application program, and including 
a second folder corresponding to a second applica- 40 
tion program and containing long-term information 
and short-term information as required by the sec- 
ond application, wherein the method further com- 
prises the steps of: 

45 

closing the second folder and leaving the first 
folder open prior to the presenting step if the 
presenting step presents the short-term certifi- 
cate to the first named application program for 
authorization, wherein closing the second fold- 50 
er makes its contents not readable by the first 
named application program; and 
closing the first folder and leaving the second 
folder open prior to the presenting step if the 
presenting step presents the short-term certifi- 55 
cate to the second application program for au- 
thorization, wherein closing the first folder 
makes its contents not readable by the second 
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